<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ARP与RARP协议详解</title>
    <link rel="stylesheet" href="https://cdn.staticfile.org/font-awesome/6.4.0/css/all.min.css">
    <link rel="stylesheet" href="https://cdn.staticfile.org/tailwindcss/2.2.19/tailwind.min.css">
    <link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;500;600;700&family=Noto+Sans+SC:wght@300;400;500;700&display=swap" rel="stylesheet">
    <script src="https://cdn.jsdelivr.net/npm/mermaid@latest/dist/mermaid.min.js"></script>
    <style>
        body {
            font-family: 'Noto Sans SC', Tahoma, Arial, Roboto, "Droid Sans", "Helvetica Neue", "Droid Sans Fallback", "Heiti SC", "Hiragino Sans GB", Simsun, sans-serif;
            background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
            min-height: 100vh;
        }
        
        .hero-gradient {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
        }
        
        .card-shadow {
            box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
            transition: all 0.3s ease;
        }
        
        .card-shadow:hover {
            transform: translateY(-5px);
            box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15);
        }
        
        .text-gradient {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }
        
        .section-divider {
            height: 2px;
            background: linear-gradient(to right, transparent, #667eea, transparent);
            margin: 3rem 0;
        }
        
        .drop-cap {
            float: left;
            font-size: 4rem;
            line-height: 1;
            font-weight: 700;
            margin-right: 0.5rem;
            color: #667eea;
            font-family: 'Noto Serif SC', serif;
        }
        
        .feature-icon {
            width: 60px;
            height: 60px;
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-size: 24px;
            margin-bottom: 1rem;
        }
        
        .timeline-dot {
            width: 20px;
            height: 20px;
            background: #667eea;
            border-radius: 50%;
            position: absolute;
            left: -10px;
            top: 5px;
        }
        
        .mermaid {
            display: flex;
            justify-content: center;
            margin: 2rem 0;
        }
        
        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }
        
        .animate-fadeInUp {
            animation: fadeInUp 0.8s ease-out;
        }
    </style>
</head>
<body>
    <!-- Hero Section -->
    <section class="hero-gradient text-white py-20 px-6">
        <div class="max-w-6xl mx-auto text-center animate-fadeInUp">
            <h1 class="text-5xl md:text-6xl font-bold mb-6">
                <i class="fas fa-network-wired mr-4"></i>
                ARP与RARP协议
            </h1>
            <p class="text-xl md:text-2xl font-light max-w-3xl mx-auto">
                深入理解网络层地址解析的核心机制
            </p>
            <div class="mt-8 flex justify-center space-x-8">
                <div class="text-center">
                    <i class="fas fa-exchange-alt text-3xl mb-2"></i>
                    <p class="text-sm">双向映射</p>
                </div>
                <div class="text-center">
                    <i class="fas fa-server text-3xl mb-2"></i>
                    <p class="text-sm">局域网通信</p>
                </div>
                <div class="text-center">
                    <i class="fas fa-shield-alt text-3xl mb-2"></i>
                    <p class="text-sm">基础协议</p>
                </div>
            </div>
        </div>
    </section>

    <!-- Main Content -->
    <main class="max-w-6xl mx-auto px-6 py-12">
        <!-- Introduction Card -->
        <div class="bg-white rounded-2xl p-8 mb-12 card-shadow">
            <p class="text-lg leading-relaxed text-gray-700">
                <span class="drop-cap">A</span>RP（Address Resolution Protocol）和 RARP（Reverse Address Resolution Protocol）是两个网络协议，ARP 和 RARP 分别解决了从 IP 地址到 MAC 地址和从 MAC 地址到 IP 地址的映射问题。ARP 用于网络通信中的正常数据包传输，而 RARP 主要用于设备启动时获取 IP 地址。现代网络中，RARP 由于 DHCP 的普及，使用较少，而 ARP 仍然是局域网通信的基本协议。
            </p>
        </div>

        <!-- Visual Diagram -->
        <div class="bg-white rounded-2xl p-8 mb-12 card-shadow">
            <h3 class="text-2xl font-bold mb-6 text-center text-gradient">协议关系图</h3>
            <div class="mermaid">
                graph LR
                    A[IP地址] -->|ARP协议| B[MAC地址]
                    B -->|RARP协议| A
                    C[设备A] -->|ARP请求| D[广播]
                    D --> E[设备B]
                    E -->|ARP响应| C
                    F[无盘工作站] -->|RARP请求| G[RARP服务器]
                    G -->|RARP响应| F
                    style A fill:#667eea,stroke:#fff,color:#fff
                    style B fill:#764ba2,stroke:#fff,color:#fff
                    style C fill:#f3f4f6,stroke:#667eea
                    style E fill:#f3f4f6,stroke:#667eea
                    style F fill:#f3f4f6,stroke:#764ba2
                    style G fill:#f3f4f6,stroke:#764ba2
            </div>
        </div>

        <!-- ARP Section -->
        <section class="mb-16">
            <div class="flex items-center mb-8">
                <div class="feature-icon">
                    <i class="fas fa-arrow-right"></i>
                </div>
                <h2 class="text-3xl font-bold ml-4">ARP（地址解析协议）</h2>
            </div>
            
            <div class="bg-white rounded-2xl p-8 card-shadow mb-8">
                <p class="text-lg leading-relaxed text-gray-700 mb-6">
                    ARP 是一种网络协议，用于将 IP 地址解析为 MAC 地址（物理地址）。在局域网中，当一台设备知道目标设备的 IP 地址时，它需要通过 ARP 协议找到对应的 MAC 地址，从而可以进行数据包的正确传输。
                </p>
                
                <h3 class="text-2xl font-semibold mb-4 flex items-center">
                    <i class="fas fa-cogs text-purple-600 mr-3"></i>
                    工作原理
                </h3>
                
                <div class="space-y-4 ml-8">
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">1. ARP 请求</h4>
                        <p class="text-gray-700">设备 A 知道设备 B 的 IP 地址，但不知道设备 B 的 MAC 地址。设备 A 发送一个 ARP 请求广播到网络中，请求包含了目标 IP 地址。</p>
                    </div>
                    
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">2. ARP 响应</h4>
                        <p class="text-gray-700">设备 B 收到 ARP 请求后，回复 ARP 响应，其中包含了设备 B 的 MAC 地址。</p>
                    </div>
                    
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">3. 缓存和通信</h4>
                        <p class="text-gray-700">设备 A 收到 ARP 响应后，将设备 B 的 IP 地址和 MAC 地址映射存储在 ARP 缓存中，然后使用该 MAC 地址将数据包发送给设备 B。</p>
                    </div>
                </div>
                
                <div class="mt-8 bg-purple-50 rounded-xl p-6">
                    <h4 class="font-semibold text-lg mb-2 flex items-center">
                        <i class="fas fa-bullseye text-purple-600 mr-2"></i>
                        主要用途
                    </h4>
                    <p class="text-gray-700">将 IP 地址映射到物理网络地址（MAC 地址），以便在局域网中正确路由数据包。</p>
                </div>
            </div>
        </section>

        <div class="section-divider"></div>

        <!-- RARP Section -->
        <section class="mb-16">
            <div class="flex items-center mb-8">
                <div class="feature-icon">
                    <i class="fas fa-arrow-left"></i>
                </div>
                <h2 class="text-3xl font-bold ml-4">RARP（反向地址解析协议）</h2>
            </div>
            
            <div class="bg-white rounded-2xl p-8 card-shadow mb-8">
                <p class="text-lg leading-relaxed text-gray-700 mb-6">
                    RARP 是一种网络协议，用于将 MAC 地址解析为 IP 地址。它通常用于设备在启动时，特别是那些没有存储持久 IP 地址的设备，如网络启动设备（例如，无盘工作站）。
                </p>
                
                <h3 class="text-2xl font-semibold mb-4 flex items-center">
                    <i class="fas fa-cogs text-purple-600 mr-3"></i>
                    工作原理
                </h3>
                
                <div class="space-y-4 ml-8">
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">1. RARP 请求</h4>
                        <p class="text-gray-700">设备发送 RARP 请求广播，包含设备的 MAC 地址。</p>
                    </div>
                    
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">2. RARP 响应</h4>
                        <p class="text-gray-700">RARP 服务器接收到请求后，根据设备的 MAC 地址从其数据库中查找对应的 IP 地址，并发送 RARP 响应给设备。</p>
                    </div>
                    
                    <div class="relative pl-8 border-l-2 border-purple-300">
                        <div class="timeline-dot"></div>
                        <h4 class="font-semibold text-lg mb-2">3. IP 地址分配</h4>
                        <p class="text-gray-700">设备接收到 RARP 响应后，得到其 IP 地址，并可以继续启动和进行网络通信。</p>
                    </div>
                </div>
                
                <div class="mt-8 bg-purple-50 rounded-xl p-6">
                    <h4 class="font-semibold text-lg mb-2 flex items-center">
                        <i class="fas fa-bullseye text-purple-600 mr-2"></i>
                        主要用途
                    </h4>
                    <p class="text-gray-700">将 MAC 地址映射到 IP 地址，以便设备能够在网络中进行通信，特别是在没有持久 IP 配置的情况下。</p>
                </div>
            </div>
        </section>

        <div class="section-divider"></div>

        <!-- Comparison Section -->
        <section class="mb-16">
            <div class="flex items-center mb-8">
                <div class="feature-icon">
                    <i class="fas fa-balance-scale"></i>
                </div>
                <h2 class="text-3xl font-bold ml-4">主要区别</h2>
            </div>
            
            <div class="grid md:grid-cols-2 gap-6">
                <div class="bg-white rounded-2xl p-6 card-shadow">
                    <div class="flex items-center mb-4">
                        <i class="fas fa-directions text-purple-600 text-2xl mr-3"></i>
                        <h3 class="text-xl font-semibold">功能方向</h3>
                    </div>
                    <div class="space-y-3">
                        